.menu-item-has-children {
position: relative;
}
li.menu-item-has-children a {
padding-right: 16px;
}
.nav-primary li a {
padding: 22px 30px;
font-size: 14px;
color: #000;
display: inline-block;
}
li.menu-item-has-children:active .sub-menu, header.banner li.menu-item-has-children:focus .sub-menu, header.banner li.menu-item-has-children:hover .sub-menu {
visibility: visible;
transform: translateY(0);
max-height: 500px;
}
header.banner .sub-menu {
visibility: hidden;
position: absolute;
transform: translateY(-100%);
transition: all .3s ease-in-out;
z-index: -10;
left: 0;
width: 160px;
top: 60px;
background: #fff;
list-style: none;
padding: 0;
padding-bottom: 14px;
padding-top: 8px;
border: 1px solid rgba(45,55,103,.2);
}